## Alterações no OrCS

trace\_reader\_t::trace\_string\_to\_opcode(...)

## trace\_reader\_t::trace\_fetch(...)

# Before
bool mem\_is\_read;
for (uint32\_t r=0; r < m->num\_reads; ++r) {

for (uint32\_t w=0; w < m->num\_writes; ++w) {

bool mem\_is\_read; uint32\_t num\_reads = (m->num\_reads != UINT32\_MAX) ? m->num\_reads : trace\_next\_num\_accesses();

for (uint32\_t r=0; r < num\_reads; ++r) { uint32\_t num\_writes = (m->num\_writes != UINT32\_MAX) ? m->num\_writes : trace\_next\_num\_accesses(); for (uint32\_t w=0; w < num\_writes; ++w) {

## trace\_reader\_t::trace\_next\_num\_accesses(...)

# Alteração em relação ao **trace\_next\_memory** 

if (file\_line[0] == '\0' || file\_line[0] == "#") { else {
 ERROR\_ASSERT\_PRINTF(file\_line[0] != '\$', "Error searching for num accesses in line
%s\n", file\_line); uint32\_t num\_accesses = (uint32\_t)strtoul(file\_line + 1, NULL, 10);
assert(num\_accesses <= MAX\_MEM\_OPERATIONS);</pre> return num\_accesses;

Problema a ser solucionado: Instruções Id/st RVV apresentam um número variado de leituras e escritas durante a execução. O atual armazenamento desse número no traço estático não

Apenas as instruções com -1 terão essa anotação para

Em seguida os <numero> acessos desse tipo.

manter a retrocompatibilidade.

Based on trace\_next\_memory

O formato da anotação é \$<numero>

dá suporte a essas variações. Solução:Instruções com esse número variado apresentarão -1 ao invés do número fixo no traço estático. O traço dinâmico vai conter uma anotação específica indicando o número de acessos dessas instruções.

## break;

Alterações no SPIKE

# Antes do switch(opcode\_hash)

op\_info.variable\_num\_reads = false;
op\_info.variable\_num\_writes = false; # Para as instruções com número variável de leituras (RVV) case ...: op\_info.variable\_num\_reads = true;

break; # Para as instruções com número variável de escritas (RVV) case ...:

orcs\_tracer\_t::fill\_instruction\_info(...)

op\_info.variable\_num\_writes = true;

orcs\_tracer\_t::memory\_trace(...)

# Adicionar entre op\_info = fill\_instruction\_info(insn, pc, opcode\_hash); // Add a marker into the memory trace

memory\_access\_t var\_reads; var\_reads.is\_num\_accesses = true; var\_reads.num\_accesses = op\_info.num\_reads; this->BBL\_mem\_accesses.push\_back(var\_reads); for (uint32\_t i=0; i < op\_info.num\_reads; ++i) {

if (op\_info.variable\_num\_reads) {

new\_op.is\_num\_accesses = false;

# Adicionar entre

// Add a marker into the memory trace
if (op\_info.variable\_num\_writes) {
 memory\_access\_t var\_writes; var\_writes.is\_num\_accesses = true;
var\_writes.num\_accesses = op\_info.num\_reads; this->BBL\_mem\_accesses.push\_back(var\_writes);

for (uint32\_t i=0; i < op\_info.num\_writes; ++i) {

new\_op.is\_num\_accesses = false;

gzwrite(...

orcs\_tracer\_t::print\_orcs\_memory\_trace(...) for (size\_t i=0; i < BBL\_mem\_accesses.size(); ++i) {
 memory\_access\_t new\_op = BBL\_mem\_accesses[i];</pre>

if (new\_op.is\_num\_accesses == false) {
 snprintf(...
} else {
 snprintf(orcs\_print\_aux, 1024, "\$%u\n", new\_op.num\_accesses);

opcode\_package\_t

# Adição bool variable\_num\_reads; bool variable\_num\_writes;

memory\_access\_t

# Adição bool is\_num\_accesses; uint32\_t num\_accesses;